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(57) A processing architecture enables execution of 
one first set of instructions (OsTaskl .1 , OsTaskl .2, ...) 
and one second set of instructions (MmTask2.1 , 
MmTask2.2, MmTask2.3, ...) compiled for being execut- 
ed by two different CPUs, the first set of instructions 
(OsTaskl .1 , OsTaskl .2, ...) not being executable by the 
second CPU, and the second set of instructions 
(MmTask2.1 , MmTask2.2, MmTask2.3, ...) not being ex- 
ecutable by the first CPU . The architecture comprises a 
single CPU (CPU3) configured for executing both the 
instructions of the first set (OsTaskl .1 , OsTaskl .2, ...) 
and the instructions of the second set (MmTask2.1 , 
MmTask2.2, MmTask2.3, ...). The single CPU in ques- 
tion (CPU3) being selectively switchable between a first 
operating mode, in which the single CPU (CPU3) exe- 
cutes the first set instructions (OsTaskl. 1, 
OsTaskl .2, ...), and a second operating mode, in which 
the single CPU (CPU3) executes the second set of in- 
structions (MmTask2.1 , MmTask2.2, MmTask2.3, ...). 
The single processor (CPU3) is configured for recogniz- 
ing a switching instruction between the first operating 
mode and the second operating mode and for switching 
between the first operating mode and the second oper- 
ating mode according to the switching instruction. The 
solution can be generalized to the use of a number of 
switching instructions between more than two execution 
modes for different CPUs. 
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Description 

Field of the invention 

[0001 ] The present invention relates to processing ar- 
chitectures and to systems that implement said archi- 
tectures. 

[0002] The invention has been developed with partic- 
ular attention paid to microprocessing architectures that 
may find application in mobile-communication systems. 
The scope of the invention is not, however, to be under- 
stood as limited to this specific field of application 

Description of the prior art 

[0003] The typical system architecture of a cell phone 
is based upon the availability (instantiation) of a number 
of central processing units (CPUs). 
[0004] These are usually two processing units, each 
of which fulfils a specific purpose. 
[0005] The first CPU performs control functions that 
substantially resemble the ones of an operating system. 
This type of application is not particularly demanding 
from the computational standpoint, nor does it require 
high performance. Usually it envisages the use of an ar- 
chitecture of a scalar pipeline type made up of simple 
fetch-decode-read-execute-writeback stages. 
[0006] The second CPU performs functions that have 
characteristics that are altogether different in terms of 
computational commitment and performance. For this 
reason, it usually envisages the use of a superscalar or 
very-long-instruction-word (VLIW) pipeline processor 
capable of issuing and executing a number of instruc- 
tions per cycle. These instructions can be scheduled at 
the compiling stage (for the VLIW architecture) or at the 
execution stage (for superscalar processors). 
[0007] This duplication of computational resources 
leads to a duplication of the requirements in terms of 
memory, with consequent greater power absorption. 
The latter can be partially limited, but not avoided, by 
alternately setting either one or the other of the CPUs 
in sleep mode. 

[0008] With reference to Figure 1 , a typical architec- 
ture for wireless applications of the type described com- 
prises two CPUs, such as two microprocessors, desig- 
nated by CPU1 and CPU2, each with a cache-memory 
architecture of its own. 

[0009] The CPU1 is typically a 32-bit pipelined scalar 
microprocessor. This means that its internal architecture 
is made up of different logic stages, each of which con- 
tains an instruction in a very specific state. This state 
can be one of the following: 

loading of the instruction from the memory; 
decoding; 

addressing of a register file; 
execution; and 

writing/reading of data from the memory. 



[0010] The number of bits refers to the extent of the 
data and instructions on which the CPU1 operates. The 
instructions are generated in a specific order by compi- 
lation and are executed in that order. 

5 [0011] The CPU2 is typically a 128-bit pipelined su- 
perscalar or VLIW microprocessor. This means that its 
internal architecture is made up of different logic stages, 
some of which can execute instructions in parallel, for 
example in the execution step. Typically, parallelism is 

10 of four 32-bit instructions (corresponding to 128 bits), 
whilst the data are expressed on 32 bits. 
[0012] A processor is said to be superscalar if the in- 
structions are dynamically re-ordered during execution 
in order to feed the execution stages that can potentially 

15 work in parallel and if the instructions are not mutually 
dependent, thus altering the order generated statically 
by the compilation of the source code. 
[0013] The processor corresponds, instead, to the so- 
lution referred to as VLIW (Very Long Instruction Word) 

20 if the instructions are statically re-ordered in the compi- 
lation step and executed in the fixed order, which is not 
modifiable during execution. 

[0014] Again with reference to the diagram of Figure 
1 , it may be seen that each processor CPU1 , CPU2 has 
25 a data cache of its own, designated by D$, and an in- 
struction cache of its own, designated by l$, so as to be 
able to load in parallel from the main memory M EM both 
the data on which to work and the instructions to be ex- 
ecuted. 

30 [0015] The two processors CPU 1 , CPU2 are connect- 
ed together by a system bus, by which the main memory 
MEM is connected. The two processors CPU1 , CPU2 
compete for access to the bus - which is achieved 
through respective interfaces referred to as core-mem- 

35 ory controllers - CMCs - when the instructions, data or 
both, on which they must operate, are not available in 
their own caches, since they are, instead, located in the 
main memory. It may be appreciated that such a system 
uses two microprocessors, with their corresponding two 

40 memory hierarchies, which are indispensable and 
somewhat costly, both in terms of occupation of area 
and in terms of power consumption. 
[0016] By way of reference, in a typical application, 
the CPU1 usually has 16 Kbytes of data cache plus 16 

45 Kbytes of instruction cache, whilst the CPU2 usually has 
32 Kbytes of data cache plus 32 Kbytes of instruction 
cache. 

[0017] Figure 2 illustrates the logic scheme of the 
CPU1. 

50 [0018] The first stage generates the memory address 
of the instruction cache l$ to which the instruction to be 
executed is associated. This address, referred to as 
Program Counter, causes loading of the instruction 
(fetch) that is to be decoded (decode), separating the 

55 bit field that defines the function (for example, addition 
of two values of contents in two registers located in the 
register file) from the bit fields that address the oper- 
ands. These addresses are sent to a register file from 
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which the operands of the instruction are read. The op- 
erands and bits that define the instructions that are to 
be executed are sent to the execution unit (execute), 
which performs the desired operation (e.g., addition). 
The result can then be re-stored in the memory (write- 
back) in the register file. 

[0019] The load/store unit enables, instead, reading/ 
writing of possible memory data, exploiting specific in- 
structions dedicated to the purpose. It may, on the other 
hand, be readily appreciated that there exists a biunivo- 
cal correspondence between the set of instructions and 
the (micro)processing architecture. 
[0020] What has been said above with reference to 
the CPU1 substantially also applies to the CPU2, in the 
terms recalled in the diagram of Figure 3. 
[0021] The main difference lies, in the case of the 
CPU2, in the greater number of execution units availa- 
ble which are able to operate in parallel in a superscalar 
and 

[0022] VLIW processor; in this connection, see the 
various stages indicated by Execute 2.1, Execute 
2.2, Execute 2.n, in Figure 3. Also in this case, how- 
ever, there exists a biunivocal correspondence between 
the set of instructions and the processing architecture. 
[0023] In architectures such as, for instance the archi- 
tectures of wireless processors, it is common to find that 
the two sets of instructions are different. 
[0024] This implies that the instructions executed by 
the CPU1 cannot be executed by the CPU2, and vice 
versa. 

[0025] Suppose, with reference to Figures 4 and 5, 
that we have to do with types of processing that take the 
form of two respective sets of instructions of this nature. 
[0026] For example, with reference to the application- 
al context (mobile communication) already cited previ- 
ously, it is possibleto distinguish two types of processes: 

processes OsTask1.1, OsTask1.2, etc., which re- 
semble operating-system processes performed by 
the CPU1; and 

processes MmTask2.1, MmTask2.2, MmTask2.3, 
etc., which regard the processing of contents (usu- 
ally multimedia contents, such as audio/video/ 
graphic contents) performed by the CPU2. 

[0027] The former processes contain instructions 
generated by the compiler of the CPU1 , and hence can 
be performed by the CPU1 itself, but not by the CPU2. 
For the second processes exactly the opposite applies. 
[0028] It may moreover be noted that each CPU is 
characterized by a compilation flow of its own, which is 
independent of that of the other CPU used. 
[0029] The diagram of Figure 5 shows how the se- 
quence of scheduling of the aforesaid tasks is distribut- 
ed between the two processors CPU1 and CPU2. 
[0030] If we set at 1 00 the total time of execution of 
the aforesaid processes, typically the former last 10% 
of the time, whilst the latter occupy 90% of the total ex- 



ecution time. 

[0031] It follows from this that the CPU1 can be con- 
sidered redundant for 90% of the time, given that it re- 
mains active only 1 0% of the time. 

5 [0032] The above characteristic may be exploited by 
turning the CPU1 off in order to achieve energy saving. 
[0033] However, the powering-down procedures in- 
troduce extra latencies of processing that are added to 
the 1 0% referred to above. These procedures envisage 

10 in fact: 

powering-down of the CPU with the exception of the 
register file by gating the clock that supplies all the 
internal registers, as well as the other units (e.g., 
15 decoding unit, execution unit) present in the core; 

complete powering-down of the CPU, maintaining 
energy supply in the cache memories; and 
powering-down of the CPU as a whole, as well as 
in the data cache and instruction cache. 

20 

[0034] From a structural standpoint, since the state of 
the processorthat characterized the processor itself pri- 
or to powering-down must be restored when the proc- 
essor is powered back up following upon the operations 
25 described previously, the latencies introduced range 
from tens of nanoseconds to tens/hundreds of millisec- 
onds. It follows that the aforesaid powering-down pro- 
cedures are costly both from the energy standpoint and 
from the computational standpoint. 

30 

Object and summary of the present invention 

[0035] The object of the present invention is therefore 
to define a microprocessing-system architecture that is 
35 able to overcome the drawbacks outlined above. 

[0036] According to the present invention, this object 
is achieved thanks to an architecture having the char- 
acteristics specified in the claims which follow. The in- 
vention also relates to the corresponding system, as 
40 well as to the corresponding procedure of use. 

[0037] Essentially, the solution according to the inven- 
tion is based upon the recognition of the fact that dupli- 
cation or, in general, multiplication of the resources 
(CPU memory, etc.) required for supporting the control 
45 code envisaged for operating according to the modali- 
ties referred to previously may be avoided if the two (or 
more) CPUs originally envisaged can be fused into a 
single optimized (micro)architecture, i.e., into a new 
processorthat is able to execute instructions generated 
50 by the compilers of the various CPUs, with the sole re- 
quirement that the said new processor must be able to 
decode one or more specific instructions such as to 
switch its function between two or more execution 
modes inherent in different sets of instructions. 
55 [0038] This instruction or these instructions are en- 
tered at the head of each set of instructions compiled 
using the compiler already associated to the CPU. 
[0039] In particular, two steps are envisaged. 
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[0040] The first step involves compiling of each proc- 
ess, using, in an unaltered way, the compilation flow of 
the CPU1 or CPU2 (in what follows, for reasons of sim- 
plicity, reference will be made to just two starting CPUs, 
even though the invention is applicable to any number 
of such units). 

[0041 ] The second step takes each set of instructions 
and enters a specific instruction at the head thereof so 
as to signal and enable mode switching between the ex- 
ecution mode of the CPU1 and the execution mode of 
the CPU2 in the framework of the optimized micro-ar- 
chitecture. 

[0042] The above involves considerable savings in 
terms of memory and power absorption. In addition, it 
enables use of just one fetch unit, which detects the 
switching instruction, two decoding units (for each of the 
two CPUs, the CPU1 and the CPU2), a single register 
file, a number of execution units, and a load/store unit, 
which is configured once the special instruction has 
been detected. 

Detailed description of the annexed drawings 

[0043] The present invention will now be described, 
purely by way of non-limiting example, with reference to 
the attached drawings, in which: 

Figures 1 to 5, which regard the prior art, have al- 
ready been described above; 
Figures 6 and 7 illustrate compiling of the tasks in 
an architecture according to the invention; 
Figure 8 illustrates, in the form of a block diagram, 
the architecture according to the invention; and 
Figure 9 illustrates, in greater detail, some structural 
particulars and particulars of operation of the archi- 
tecture illustrated in Figure 8. 

Detailed description of an examplary embodiment of the 
invention 

[0044] As already mentioned, the main idea underly- 
ing the invention corresponds to the recognition of the 
fact that, in order to support execution of processes of 
low computational weight (for example, 10% of the 
time), no duplication of the processing resources is nec- 
essary. 

[0045] As is schematically represented in Figure 6, 
the solution according to the invention envisages defi- 
nition of a new processor or CPU architecture, desig- 
nated by CPU3, which enables execution of processes 
designed to be executed, in the solution according to 
the known art, on two or more distinct CPUs, such as 
the CPU1 and CPU2, without the applications thereby 
having to be recompiled for the new architecture. 
[0046] Basically, the solution according to the inven- 
tion aims at re-utilizing the original compiling flows en- 
visaged for each CPU, adding downstream thereof a 
second step for rendering execution of the correspond- 



ing processes compatible. 

[0047] In particular, with reference to Figure 7, con- 
sider, in a first compiling step, the source code in a proc- 
ess OsTaskl .1 for the operating system. In a traditional 
5 architecture, such as the one illustrated in Figure 1 , the 
corresponding instructions should be executed on the 
CPU1 , using the corresponding compiler. 
[0048] Considerthen, in the same first step, compiling 
of the source code of a process (MmTask2.1), for a mul- 
timedia audio/video/graphics application, which, in atra- 
ditional architecture, such as the one illustrated in Figure 
1, would be executed on the CPU2, also in this case 
using the corresponding compiler, which is different 
from the compiler of the CPU1 . It should moreover be 
recalled that, in a scheme such as the one illustrated by 
the diagram of Figure 1 , the two processors CPU1 and 
CPU2 have an architecture of independent sets of in- 
structions. 

[0049] Now consider a second step, following upon 
which (at least) one special new instruction is entered 
at the head of the ones just generated. This special in- 
struction enables identification of membership of the in- 
structions that follow the corresponding set of instruc- 
tions. This special instruction thus represents the instru- 
ment by which the CPU3 is able to pass from the exe- 
cution mode for the set of instructions of the CPU1 to 
the execution mode for the set of instructions of the 
CPU2, and vice versa. 

[0050] Figure 8 shows how the architecture of Figure 
1 can be simplified from the macroscopic point of view 
by providing a single CPU, designated by CPU3, with 
associated respective cache memories, namely the da- 
ta cache memory D$ and the instruction cache memory 
l$. The corresponding memory subsystem does not 
therefore involve a duplication of the cache memories 
and removes the competition in requesting access to the 
main memory MEM through the interface CMC, which 
interfaces on the corresponding bus. There derives 
therefrom an evident improvement in performance. 
[0051] On the other hand, the processor CPU must 
be able to execute instructions generated by the corre- 
sponding compiler both to be executed on a processor 
of the type of the CPU1 and to be executed on a proc- 
essor of the type of the CPU2, this likewise envisaging 
the capability of execution of the control instructions of 
the execution mode between the two CPUs. 
[0052] Figure 9 shows the logic scheme of the CPU3 
here proposed. 

[0053] The instructions are addressed in the memory 
through a single program counter and are loaded by the 
unit designated by Fetch & Align. The latter in turn sends 
the instructions to the decoding units compatible with 
the sets of instructions of the CPU1 and CPU2. Both of 
these are able to detect the presence of the special in- 
struction for passing the execution mode for the set of 
instructions 1 to the execution mode for the set of in- 
structions 2, and vice versa. The flag thus activated is 
sentto all the units present in the CPU so as to configure 
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its CPU1- or CPU2-compatible mode of operation. In 
particular, in the diagram of Figure 9, this flag has been 
identified with a signal designated as 
Model_NotMode2flag. In the simplest embodiment, this 
flag has the logic value "1" when the CPU operates on 
the set of instructions of the CPU1 , and the logic value 
"0" when the CPU3 operates on the set of instructions 
of the CPU2. Of course, it is possible to adopt a conven- 
tion that is just the opposite. 

[0054] The subsequent instructions loaded are de- 
coded (stages designated by Dec1 and Dec2), separat- 
ing the bit field that defines their function (for example, 
addition) from the bit fields that address the operands. 
[0055] The corresponding addresses are sent to a 
register file from which the operands of the instruction 
are read. 

[0056] The operands and the bits that define the func- 
tion to be executed are sent to the multiple execution 
units (Executel , Executem; Execute2.2, 

Executem+1 , Executen, execute ...) which perform 
the requested operation. The result may then be stored 
back in the register file with a writeback stage that is 
altogether similar to the one illustrated in Figures 2 and 
3. 

[0057] The load/store unit enables, instead, reading/ 
writing of possible data from/in the memory, and there 
exist instructions dedicated to this purpose in each of 
the operating modes. 

[0058] It will be appreciated, in particular, that the 
units that are compatible with'the execution mode, cur- 
rently not used (for instance, the decoding units Dec1 
and Dec2), can be appropriately "turned off" in order not 
to consume power. 

[0059] Of course, without prejudice to the principle of 
the invention, the details of construction and the embod- 
iments may vary widely with respect to what is described 
and illustrated herein, without thereby departing from 
the scope of the present invention as defined in the at- 
tached claims, it being in particular evident that the so- 
lution according to the present invention can be gener- 
alized to the use of a number of switching instructions 
between more than two execution modes for different 
CPUs. 



Claims 

1 . A processing architecture for executing at least one 
first set of instructions (OsTaskl .1 , OsTaskl .2, ...) 
and one second set of instructions (MmTask2.1 , 
MmTask2.2, MmTask2.3, ...) compiled for being ex- 
ecuted by a first CPU (CPU 1 ) and by a second CPU 
(CPU2), said first set of instructions (OsTaskl. 1, 
OsTaskl .2, . . .) not being executable by said second 
CPU and said second set of instructions 
(MmTask2.1 , MmTask2.2, MmTask2.3, ...) not be- 
ing executable by said first CPU, the architecture 
being characterized in that it comprises a single 



processor (CPU3) configured for executing both the 
instructions of said first set (OsTaskl. 1, 
OsTaskl .2, ...) and the instructions of said second 
set (MmTask2.1 , MmTask2.2, MmTask2.3, ...), said 

5 single processor (CPU3) being selectively switcha- 

ble at least between one first operating mode, in 
which said single processor (CPU3) executes said 
first set of instructions (OsTaskl .1 , OsTaskl .2, ...), 
and one second operating mode, in which said sin- 

10 gle processor (CPU3) executes said second set of 
instructions (MmTask2.1 , MmTask2.2, 

MmTask2.3, ...), said single processor (CPU3) be- 
ing configured for recognizing at least one switching 
instruction (Model _NotMode2 flag) at least be- 

15 tween said first operating mode and said second 
operating mode and for switching between said first 
operating mode and said second operating mode 
according to said at least one switching instruction. 

20 2. The architecture according to Claim 1 , character- 
ized in that said single processor (CPU3) has as- 
sociated to it a single cache for the data (D$). 

3. The architecture according to Claim 1 or Claim 2, 
25 characterized in that said single processor 

(CPU3) has associated to it a single cache for the 
instructions (l$). 

4. The architecture according to any one of the pre- 
30 ceding claims, characterized in that said single 

processor (CPU3) has associated to it a single in- 
terface (CMC) for dialogue via a bus with a main 
memory. 

35 5. The architecture according to any one of the pre- 
ceding claims, characterized in that a single pro- 
gram counter is provided for addressing said in- 
structions in memory. 

40 6. The architecture according to any one of the pre- 
ceding claims, characterized in that said single 
processor (CPU3) comprises at least one first de- 
coding module (DEC1 ) and at least one second de- 
coding module (DEC2) for decoding, respectively, 
45 the instructions of said first set (OsTaskl. 1, 
OsTaskl .2 ...) and, of said second set (MmTask2.1 , 
MmTask2.2, MmTask2.3 ...). 

7. The architecture according to any one of the pre- 
50 ceding claims, characterized in that it comprises 

a unified file of registers (Register File) for reading 
the operands of the instructions of said first set 
(OsTaskl. 1, OsTaskl .2 ...) and the instructions of 
said second set (MmTask2.1, MmTask2.2, 
55 MmTask2.3 ...). 

8. The architecture according to any one of the pre- 
ceding claims, characterized in that it comprises 
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units that are selectively de-activatable when they 
are not involved in the execution of instructions in 
said first functioning mode or said second function- 
ing mode. 

. A processing system implementing the architecture 
according to any one of the preceding claims from 
Claim 1 to Claim 8. 



0. A method of using a processing system according 10 
to Claim 9, characterized in that it comprises the 
operations of: 

compiling sets of instructions of said at least 

one first set (OsTaskl .1 , OsTask1.2, ...) and 15 

said at least one second set (MmTask2.1 , 

MmTask2.2, MmTask2.3, ...); and 

providing said at least one switching instruction 

(Model_NotMode2 flag) at the head of said sets 

of instructions. 20 



1. The method according to Claim 10, characterized 
in that it comprises the operations of: 

compiling each process, using in an unaltered 25 
way the compilation flow of said first CPU 
(CPU1) and said second CPU (CPU2); and 
entering said switching instruction 
(Model_NotMode2 flag) at the head of said sets 
of instructions. 30 
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